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TITLE OF THE INVENTION 

METHOD AND APPARATUS FOR PERPORMINO 
CUT -THROUGH VIRTUAL CIRCUIT MERGING 

CROSS REFERENCE TO RELATED APPLICATIONS 

NOT APPLICABLE 

STATEMENT REGARDING FEDERALLY SPONSORED RESEARCH OR 

DEVELOPMENT 

NOT APPLICABLE 

BACKGROUND OF THE INVENTION 
This invention relates to teleconnmmications networks 
and more particularly to a method and apparatus for 
performing virtual circuit merging in a connection based 
network. 

In a connection based network, such as an Asynchronous 
Transfer Mode {ATM) network, packets are transmitted over 
virtual connections or circuits- Virtual circuits are 
established at call setup between a packet source and a 
packet destination- In the ATM environment, the Virtual 
Connections are defined by Virtual Path Identifier (VPI) and 
a Virtixal Coimection Identifier (VCI) field© within the ATO 

cell header. 

Since ATM networks are connection-oriented, carrying 
connectionless traffic such as that based upon the Internet 
Protocol (IP) is problematic. SeversJ. methods exist for the 
routing of such information within an ATM network. The 
simplest form of mapping involves the assignment of a unique 
viartuftl circuit for each source and destination pair at the 
network switch- This technique, however, leads to the 
proliferation of connections or virtual circuits at each 
switch and results in large buffer requirements for 
connection identifier lookup tables in each network switch. 
Additionally, such an assignment technique is coir^utationally 
intensive as a result of the need to process voluminous 
connection setup and tear down requests . 
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Vaxlous techniques have been piropooed to minimixe the 
need to establish a imique connection for each source 
destination pair. In one technique, known as Virtual Path 
merging, the Virtual Path (VPI) address labels, are used to 
identify the destination of the packet and all packets being 
forwarded to the same destination en^loy the same VPI. The 
Virtual Connection Identifier is eniployed to identify the 
packet souirt;e. Thus, in a network employina VP mer-ging , a 
recipient of cells arriving over a single virtual path can 
identify the sender and reconstruct the packets even if the 
cells are interleaved. This technique, however, has a 
significant limitation. Since the Virtual Path Identifier 
field in the ATM cell header comprises a 12 bit field at the 
network to network interface, only 4096 virtual Paths can be 
supported. The assignment of a single Virt\ial Path per 
destination, irrespective of the number of connections 
associated with the Virtual Path, is undesirably limiting 
with regard to the number of destinations that may be 
supported in the network. Thus, VP merging is typically 
wasteful of virtual connection assignments. 

Virtual connection merging is a technique for f oirwarding 
all packecs destined for the same destination address over 
the same VPI/VCI address. In order for the destination to 
successfully delineate packets from different sorirces, the 
cells coir^rising a packet must not be interleaved over the 
virtual connection. Accordingly, packets are typically 
assembled in a buffer on an egress Input Output (l/O) Module 
of a switch and are not scheduled for transmission until an 
End oC Packet <EOP) indication i» received. Only after all 
cells coTT^rising a packet have been assembled in an egress 
I/O module buffer and an EOP received, is the packet 
scheduled for transmission over the respective Virtual 
Connection. 

While the above described VC merging technique avoids 
problems introduced by the interleaving of cells of different 
packets, it has certain dioadvantageo - Pirot, as a 

consequence of the need to fully buffer all packets prior to 
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transmissi<pn in a store and forward manner and the fact ttiat 
the packets may be vBxiably sized, the reassembly buffers 
need to be quite large. Additionally, imdesir2ible delays 
occur because the packet must be reassembled at each 
intermediate network node between the source and the 
destination. Each time the packet is reassembled, additional 
delays may be introduced. 

Ic would therefore be desirable to be able to perform 
Virtual Connection (VC) merging while minimizing the 
aforementioned problems associated with prior VC merging 
techniques. 

BRIEF SUMMARY OF THE INVENTION 
A method and apparatus for performing virtual circuit 
merging in the egress port of a network switch is disclosed. 
Cells belonging to different packets are associated with a 
imique connection identifier (CID) upon arrival at an ingress 
port of the network switch. The connection identifiers 
(CIDs) for respective VPI/VCI addresses are assigned within 
the network switch at call setup as an administrative 
function. An identification of CIDs identifying packets to 
iDe merged ovex* a single virtual circuit are associated with 
a single group identifier (GID) .within the switch. If a 
packet associated with a GID has been fully received it is 
scheduled for transmission and transmission of the packet is 
initiated- If no packets associated with the GID have been 
completely assembled but one or more packets have been 
partially received, a paxtially received packet is identified 
in accordance with a predetermined selection technique and 
cut -through transmission of the selected packet from the 
network switch is initiated prior to the completion of 
reception and reassembly of the packet. 

At the time the transmission of the partially received 
packet is initiated a timer is started. If the timer expires 
prior to receipt of an end of packet (EOP) indicator for the 
packet in transit, an EOP indicator ia transmitted from the 
output port over the merged connection and the balance of the 
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incoming packet is disircgarded. In the above deocribed 
maimer, buffering requirements at the egress port and 
undesirable delays resulting from the need to schedule a 
packet only after it has been completely received are 
avoided - 

BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWING 

The invention will be more fully understood by arefeirence 
to the following Detailed Description of the Invention in 
conjunction with the several views of the drawing of which: 

Pig. 1 is a block diagram of a network switch in 
accordance with the present invention ; 

Fig. 2 is a block diagram of an egress portion of em I/O 
module in accordance with the present invention ; 

Fig. 2a is » timer value table optionally employed in 
the presently disclosed virtual connection merging technique ; 
and 

Fig. 3 is a flow chart illustrating the virtual circuit 
method in accordance with the present invention. 

DETAILED DESCRIPTION OF THE INVENTION 
An. improved method and apparatus for performing virtual 
circuit merging in a network switch is disclosed which 
minimizes inherent deliays in store and forward virtual 
circuit merging techniques and additionally provides the 
ability to utilize smaller reassembly cell buffers « 

Referring to Fig. 1 a network switch 10 in accordance 
with the present invention is depicted which incorporates the 
ability to perform cut-through virtual circuit merging. The 
network switch includes a plurality of input or ingress ports 
12, identified herein as 12a, 12b, ..12n, for receiving 
packets from one or more ingress communication links 14 
identified herein ais 14a, 14b, ...14n, and a plurality of 
output or egress ports 16, identified herein as 16a, 
16b, . . -16n, for transmitting packets from each of the output 
porto to one or more egress communications links 18, 
identified herein as 18a, 18b, -..ISn, which are coupled to 
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the reapective output ports 16. A pacJcet comprises one or 
more cells, such as ATM cells. The end of a packet is 
signaled by an end of packet (BOP) indicator- A switch 
faJDric 20 is operative to forward cells received at the input 
porta to one or more of the output ports 16 in accordance 
with forwarding techniques known in the art. 

Upon reception at an input port, each cell is associated 
with ei connection identifier (CID) which is employed within 
the network switch 10 to specify cell routing. Typically, 
the CID is generated upon receipt of a cell in an ATM network 
switch by performing a table lookup on the VPI/VCI address 
or some portion thereof to locate the CID for the respective 
cell- In the event that the cell is a multicast or broadcast 
cell intended for transmission out of more than one port, or 
pltiz-al links coupled to a single poart (not shown) , a 
multicast identifier (MID) is associated with the cell in the 
network switch upon reception to identify the cell as a 
multicast or broadcast cell. For sin^licity, MIDs are 
considered herein as one form of CID. 

The output ports 16a through 16n includes cell buffers 
22a through 22n for buffering cells for transmission on a per 
virtual connection baaia. Thus, the cell buff ex 22a for 
output port 0 includes a plurality of cell buffers; i.e. one 
for each virtual connection assigned at call setup which 
utilizes output port 0. The output ports 16a through 16n 
further include cut -through control and support logic 17 a, 
17b, ••,17n for controlling cut-through merging of virtual 
connections having the same VPI/VCI address as herein 
desc3ribed. 

As described above. Virtual Connection (VC) merging 
involves the trajisraission of packets having the same VPI/VCI 
address and which are received over one or more input ports 
from an output port 16 of the network switch 10 over a single 
virtual connection. For exanple, assume cells comprising a 
first packet having a VPI/VCI address of VPI=3/VCI=32 are 
received at Input Port 0. A first connection identifier 
(CID-A) is associated with the cells of the first packet at 
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inpuc port O. Fxxrtliei: aasunre a second packet is rcceiveci at 
input port 1 having a VPI/VCI address of VPI-3/VCI=32 . A 
second connection identifier (CID-B) is associated with the 
cells of the second packet at input port 1. The cells are 
forwarded through the switch fabric 20 to one or more of the 
output ports 16 and are stored in cell buffers 22 on a per 
Virtual Connection basis. Thus, one cell buffer is allocated 
for each virtual connection supported by the respective 
output port 16. The first and second packets, having the 
same VPI/VCI address, may be associated with a common group 
identifier (GID) , and merged for transmission over a single 
virtual connection. 

A block diagram illustrating the components within an 
Output Port 16 enployed to implement cut-thxough VC merging 
is depicted with greater detail in Fig, 2. Referring to Fig, 
2, an output port 16 receives cells from the switch fabric 
20. Each cell has associated therewith a connection 
identifier (CID) which is employed within the network switch 
to determine cell routing. Each cell received at an output 
port 16 is stored within a cell buffer 40. The cell buffers 
for the respective virtual connections are identified in Fig. 
2 as cell buIXers 40a, 40b,... 40n- Thus, cells are stored 
within cell bxif fers within the output port on a per virtual 
connection basis. The connection identifier associated with 
the cell is employed to identify the cell buffer in which the 
respective cell is stored. 

Cells belonging to different packets (from different 
sources) arrive at the output port with CID designations that 
are locally imique to the respective output poart. A Buffer 
Memory 41 is provided in each output port. The Buffer Memory 
41 contains cell buffers for packet reception and reassembly, 
such as buffers 40a, 40b, . . ,40n and additionally, fields for 
storage of data employed to support virtual circuit merging 
as hereinafter discussed. The buffer memory, in one 
embodiment of the invention, is indexed by the CIDs. For 
each of the CIDb, at call setup time, a vuaique groxip 
identifier (GID) is assigned for all CIDs to be merged on the 
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outt>crund virtual connection and ttie GID associated with the 
CID is stored within the Buffer Memory 41. Otherwise stated, 
CIDs corresponding to incoming packets to be merged orver a 
single outgoing virtual connection are assigned a common GID. 
Thus, as depicted in the exemplary embodiment, the first 
three CIDs contained within the Buffer Memory 41 all have a 
common GID and thus will be merged over a single outgoing 
virtual connection from the respective output port 16. 
Packets associated with the same GID are meant to be merged 
onto the same virtual connection and hence, cells of the 
respective packets must not be interleaved. 

Referring to Fig. 2, cells received at the output port 
16 are stored within the appropriate cell buffer 40 
associated with the CID for the respective cell- If the CID 
is one of a plurality of CIDs having a common group ID (QID) , 
the GID identifier is also stored in association with the 
cell buffer within the buffer memory 41. 

A first flag (P) is also stored in association with the 
cell buffer which indicates whether or not a complete packet 
has been received and stored within the respective cell 
buffer. An End of Packet (EOP) Detector 44 monitors incoming 
cells and oignals Cut -through control logic 4 6 when an EOP 
is detected. The control logic 46 causes the P flag to then 
be set for the corresponding CID thus indicating that a 
complete packet has been received. More specifically, if 
transmission of a packet has not been commenced via cut- 
through as hereinafter discussed and an BOP condition is 
detected by the BOP detector 44, the F flag is eet via the 
cut through control logic to indicate that a complete packet 
has been stored within the respective cell buffer 40. The 
cut-through control logic 46 is also coupled to a transmit 
scheduler 48 which schedules completely assembled packets for 
transmission over the respective egress communications link 
18. 

A second flag (P) is also stored in the buffer memory 
41 in aaaociation with the cell buffer for each CID. The P 
flag indicates whether a packet has been partially received 
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and more specif ica.lly whether at leaet one cell of a packet 
has been stored within the cell buffer for the respective 
virtual connection. 

The Buffer MeTnoxy 41 may optionally include a Timer 
Identifier (Timer ID) stored in association with each CID 
which is employed to specify the value of a timeout timer as 
hereafter discussed. If employed, the Timer Id is specified 
at call setup and may bo modified dynamical ly diurlng eye tern 
operation. 

The Buffer Memory may also optionally include a cell 
count stored in association with each CID. The cell count 
comprises an Identification of the number of cells of the 
respective packet which have been received and stored in the 
respective one of the reassembly cell buffers 40a, 
40b, . .«40n. The cell count is generated by a cell coimter 
45 which counts received cells for an incoming packet. The 
output of the cell coxmter 45 is coupled to the cut-through 
control logic 46 which loads the count into the appropriate 
location within the buffer memory 41. 

In conventional network switches which etJtpport virtual 
circuit merging, the scheduler only schedules packets for 
transmission which have been coniplately i-eceived and 
reassembled within the output port cell buffer. In this 
manner, it can be assured that the entire packet can be 
transmitted without interleaving cells of any other packet. 
As discussed hereinabove, such is highly undesirable because 
transmission or the portion of packets which have been 
partially received and stored in a cell buffer 40 are delayed 
until the packet has been completely z-eceived. 

The presently disclosed transmit scheduler stores the 
identity of fully assembled packets \^ich are available for 
transmission within a scheduler queue 50. So long as there 
are coirrpletely assembled packets available for transmission, 
the transmit scheduler causes such packets to be transmitted 
downstream over the egress communication link 18, 

The present scheduler*, however-, differs from 
conventional schedulers in that it does not wait until a 
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paclcet has ]:>een completely received in the event ther-e aare 
no fully reassembled packets scheduled for transmiasion. 
More specifically, the transmit scheduler first determines 
whether there are any fully assembled packets available for 
transmission and schedules such packets for transmission, 
such is determined by ascertaining whether there are any 
packets identified for transmission in the Scheduler Queue 
so and by testing the P flag associated with each virtual 
connection buffer to determine if any of such flags are set 
for the respective GID- If there are no fully assembled 
packets scheduled for transmission and there are no 
completely assembled packets within the Buffer memory; i.e. 
no F flags are set within the Buffer memory 41, an indication 
of such condition is provided by the transmit scheduler 48 
to the cut through control logic 46. The cut through control 
logic then tests the P flags for the respective Virtual 
connections within the buffer memory to determine if there 
are any partially received packets. If there are no 
completely assembled packets available for transmission but 
there is at least one partially received packet within the 
cell buffer 41, a partially received packets is selected for 
out-through tranemiseion. Cut-through transmission implies 
that transmission of the partially received packet from the 
output port is initiated prior to receipt and storing of the 
entire packet within the respective cell buffer 40 of the 
buffer memory 41, 

In the event more than one partially received packet is 
stored in the buffer memory and associated with the same GID, 
one packet is selected for transmission via a predetermined 
selection techniq[ue. For example, in one embodiment, the 
first partially received packet detected by the cut-through 
logic which is associated with a valid CID may be selected 
for transmission, for example, via use of a round robin 
scheduler. In another embodiment, a count is maintained of 
the number of cells stored in the buffer for each virtual 
connection and the partially received packet having the 
largest number of buffered cells is selected for 
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tarcmsmiosion. The cell count as deaoaribed hereinabove ie 
maintained within the cell count field of the buffer memory 
41. In another embodiment, a timeout timer value is 
identified for each virtual connection and the packet is 
selected with the smallest timer value in order to minimize 
the impact on the scheduler should additional fully assembled 
packets be determined to be available for transmission. The 
timeout timear value may actually be stored within the Timer 
Id field within the Buffer Memory or alternatively, the Timer 
ID field may be used to store an index into a timer value 
selection table 54 such as depicted in Fig. 2a. The 
utilization of the timeout timer is discussed in greater 
detail below. Any other suitable selection technique for 
selecting a partially assembled packet for transmission may 
also be employed. 

Once a partially received packet has been selected for 
transmission, transmission of the pac3cBt is initiated by the 
cut-through control logic 46. At the time transmission of 
the partially received packet is commenced a timeout timer 
52 is started. The length of the timeout period may be 
specified for each CID or for each GID. More specifically, 
the timer -value may be loaded with a value eolected for a 
particular CID or GID specified by the Timer Id field for the 
respective CID within the Buffer Memory 41. In this manner 
timeout values may be specified based upon the type of 
traffic associated with the respective connections. In the 
event that a timeout value is selected based upon the timer 
identifier field, the timer 52 is loaded with the timer 
timeout -sralue prior to transmission of * the packet and 
initiation of the timeout timer. The timer timeout values 
may be stored in the timer value table 54 as depicted in Fig. 
2a or in any other suitable data structure. 

To SLvoLa the possibility that commencement of 
transmission of a cut-through packet will introduce 
unacceptable delays or hang up the scheduler in the event of 
upstream congestion or a failure to receive the remainder of 
a packet which has commenced cut-through transmission, the 
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cut- through control logic 46 monitors tlx© timeout timer S2 
and the BOP Detector 44. If the cut-through control logic 
determines that the EOP detector has detected an EOP for the 
cut- through packet prior to expiration of the timeout timer* 
the timer is reset and control is passed to the transmit 
scheduler to determine if there are any fully assembled 
packets then available for transmission. Alternatively, if 
the cut -through control logic 46 detects the expiration of 
the timeout timer prior to the detection of an EOP signal for 
the cut- through packet, the cut- through control logic 46 
causes the cut -through packet to cease transmission and 
causes an EOP generator 56 to generate an BOP signal for 
transmission over the egress communication link 18. The 
remainder of the cut -through, packet received following the 
ceoaation of transmioaion of the packet and insertion of th© 
EOP signal is disregarded and the F flag is not set upon 
receipt of the EOP signal- Similarly, the P flag is not set 
and the cell count is cleared to assure that the control 
logic 46 and the scheduler 48 do not improperly respond to 
the receipt of the remainder of the cell following the 
aborted cut through transmission. Control is then passed to 
the transmit scheduler to determine if there are any fully 
assembled packets available for transmission as discussed 
hereixiabove . 

The method of operation of the presently disclosed cut- 
throiagh virtual circuit merging technique is further 
illustrated in Pig- 3. As depicted In step 100, upon receipt 
of cells at the output port con5)rising part of a packet, the 
cells are stored in cell buffers for the respective CID. Ass 
illustrated in decision step 102, inquiry is made whether 
there are any fully assembled packets available for 
transmission for the respective GID- If there are one or 
more fully assembled packets available for transmission such 
packets are identified in the scheduler queue 50. If there 
are no fully assembled packets available for transmission, 
inquiry is made whether there are any partially received 
packets for the respective GID as illustrated in step 106. 
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If there enre no partially receivod packets available for 
transmission and no fully assenibled packets available for 
transmission, control passes back to step 100 and the process 
continues. If there are any partially received packets 
available for transmission as determined via the inquiry step 
106, one of the partially received packets is selected for 
cut -through transmission in accordance with predetermined 
selection criteria ae depicted in otep 108. Cut-through 
transmission of the selected packet is initiated as 
illustrated in step 110 and a timeout timer is initiated 
using either a predetermined timeout value or one selected 
as discussed hereinabove. If the EOP detector detects the 
arrival of the EOP for the cut -through packet prior to the 
expiration of the timeout timer 52, the fields within the 
Buffer Memory 41 are updated to clear the P and P flags, to 
clear the cell count (if used) , and control passes back to 
step 100. If the EOP detector did not detect the EOP for the 
cut -through packet prior to expiration of the timeout timer 
52, the cut-through control logic 46 aborts the cut-through 
transmission of the packet and signals the EOP generator to 
transmit an EOP signal over the egress communication link as 
depicted in step 114. The balance of the out-through packat 
is disregarded, as depicted in step 116, the F, P and cell 
count (if used) are cleared and control returns to step 100. 
More specifically, the cut-through control logic 46 marks the 
CID so that the remainder of the packet is flushed from 
memoiry upon receipt. 

In the above described manner, packet retransmission 
delays eire minimired and cell buffering recruirements may be 
reduced while assiiring that packets merged over a single 
virtual connection are not interleaved. Additionally, undue 
delays are not introduced in the event of upstream congestion 
which delays receipt of the balance of a cut -through packet 
or in the event the balance of the packet will not be 
received due to the fact that the transmission of the packet 
wao aborted by an upstream network device or as a confieqfuonco 
of an upstream treuismisBion failure - 
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While the cut-through control logio has been depicted 
separately from the transmit scheduler for pxirposes of 
illustration, it should be. appreciated that the control logic 
associated with the cut-through functions herein described 
may be incorporated within the scheduler 48. 

Additionally, it should be appreciated that 
prioritization of the GIDs may be employed to assixre 
appropriate <iualitioo of service for the respective usero of 
the various merged virtual connections - 

It will further be appreciated by those of ordinary 
skill in the art that other modifications of and variation 
from the presently disclosed methods and apparatus for 
performing cut-through virtual circuit merging may be 
en^>loyed without departing from the inventive concepts 
disclosed herein- Accordingly, the invention is not to be 
viewed as limited except as by the scope and spirit of the 
appended claims. 
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What is claims is: 

1. A method for performing cut-through virtual connection 
merging at a network switch in a connection based network; 

determining whether any fully received packets are 
available for transmission over a virtual connection? 

if there are no fully received packets available for 
tranBmiBoion over said virtual connection, deteirmining 
whether there are any partially received packets available 
for cut-through transmission over said virtual connection; 

if there is at least one partially received packet 
available for transmission over said virtual connection, 
selecting a partially received packet for cut-through 
transmission from said at least one partially received 
•packet ; 

initiating cut-through transmission of said partially 
received packet over said virtual connection; 

generating and transmitting over said virtual connection 
an End of Packet (EOP) indication in the event an End of 
Packet signal is not received for the packet imdergoing cut- 
through transmission prior to expiration of a predetermined 
period following the initiation o£ tranamisaion of said cut- 
through packet. 

2. The method of claim 1 further comprising the step of: 
disregarding the remainder of said packet following 

expiration of said predetermined period. 

3. The method of claim 1 wheirein said initiating step 
further includes the step of initiating a timer having a 
preset expiration period upon initiation of transmission of 
said partially received packet and said generating step 
further comprises the step of transmitting an End of Packet 
indication if said end of packet signal is not received for 
the packet undergoing cut -through transmission prior to 
ejcpiration of said timer eacpiration period* 
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4 . The method of claim 1 wherein said oelecting t3tep 
compriBes the step of selecting the first partially received 
packet for cut-through transmission which is eligible for 
cut -through transmission and which is detected by a packet 
scheduler. 

5. The method of claim 4 wherein said selecting step 
further compriseo the atep of testing packets fox cut -through 
eligibility in a round robin sequence and selecting the first 
partially received packet which is detected in said round 
robin sequence that is eligible for cut- through transmission. 

6. The method of claim 1 wherein said selecting step 
further conrvprises the step of associating a timer val.ue with 
each packet that is eligible for cut through tronamiseion and 
selecting the packet for cut -through transmission having the 
smallest timer value. 

7. The method of claim 1 wherein said selecting step 
further coitqprises the steps of: 

maintaining a cell cormt of cells received for each 
packet eligible for cut-through transmission and 

selecting a packet for cut through transmission having 
the largest cell count from the packets eligible for cut- 
through transmission _ 

8. The method of claim 1 wherein said method further 
comprises the steps of : 

at call set\;^, asaigniiig a plurality of connection 
identifiers or ingress connections associated with 
corresponding VPI/VCI addresses ; 

at call setup associating said plurality of connection 
identifiers with a group identifier specifying a single 
egress virtual connection a received packet having a VPI/VCI 
address associated with one of said plurality of connection 
identifiers ; 



PACE 31/103 * RCVD AT 4/7/2005 4:50:25 PM [Eastern Daylight TImel * SVR:USPTO-EFXRF-1/4 * DNIS:8729306 * CS1D:5123479224 * DURATION (mm-ss):32-52 



04/07/05 15:01 FAX 5123479224 



^ USPTO PAT 



81032 



WO 99/27688 PCT/US98/24721 

-16- 

wherein ©aid packet selected fox cut-through 
transmission merging is selected from packets associated with 
said group identifier. 

9. Packet scheduling apparatus for merging packets received 
by a network switch in a connection based network for 
transmission from an output port of said network switch over 
o virtual cozmection corapr-ioing; 

a plurality of cell buffers for storing in said network 
switch packets, associated with a corresponding plurality of 
connection identifiers wherein each of said plurality of 
connection identifiers is associated with a group identifier 
identifying packets to be merged over said single virtual 
connection; 

a timer- operative to produce a timeout signal a 
predetermined period following activation of said timer; and 
a scheduler, 

said scheduler being operative to schedule a fully 
assembled packet received within one of said plurality 
of cell buffers for transmission over said virtual 
connection in the event a fully assembled packet is 
Available for traxismiosioxx; 

said scheduler being further operative to initiate 
transmission of a partially received packet stored 
within one of said plurality of cell buffers in the 
event no fully assembled packets are available for 
transmission and to activate said timer upon initiation 
of transmission of said partially received packet; and 

aaxd acheduler being further operative to generate 
* and transmit an end of packet signal in the event said 
scheduler detects said timeout signal prior to the 
completion of reception of said partially received 
packet with the respective one of said cell buffers. 

10, The packet scheduling apparatus of claim 9 wherein said 
scheduler io further operative to disregard the remainder of 
said partially received packet following detection of said 
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timeo\Jt signal in the event said scheduler detects said 
timeout signal prior to the completion of reception of said 
partially received packet. 

11. The packet scheduling apparatus of claim 9 wherein a 
cixner value is stored in the respective cell buffer 
associated with each connection identifier associated with 
said group identifier and said timer predetermined period is 
selected based upon the connection identifier for the 
respective packet. 

12. The packet scheduling apparatus of claim 9 wherein said 
timer predetermined period is selected based upon the group 
identifier. 

13. The packet scheduling apparatus of claim 9 wherein a 
pointer to a timer value stored in a timer value table is 
stored in the cell buffer associated with each connection 
identifier associated with said group identifier and said 
timer predetermined period is selected based upon the 
specified value within said timer value table. 

14 . The packet scheduling apparatus of claim 9 wherein said 
partially received packet conprises at least one cell stored 
within the respective cell buffer. 

15. The packet scheduling apparatus of claim 14 wherein said 
at least one cell con^rises at least one Asynchronous 
Transfer Mode cell. 

16. ThB packet scheduling apparatus of claim 9 wherein said 
scheduler is operative to select the first partially received 
packet which is detected and eligible for transmission over 
said virtual connection. 

17. The packet schediiling apparatus of claim 16 wherein said 
scheduler is operative to test said cell buffers associated 
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with. said group identifier to identify paxtiailly ^received 
packets eligible for transmiBsion in a round robin sequence. 

18 . The packet schediiling apparatus of claim 9 wherein a 
timer value is associated with each connect ion identifier and 
employed to specify said timer predeteirmined period and said 
scheduler is operative to select for transmission the 
partially received packet associated with the einkallest timer 
value in the event there are no fully received packets 
associated with said group identifier available for 
transmission, 

19. The packet scheduling apparatus of claim 9 wherein a 
cell count identifying the number of cells stored within the 
cell buffer is maintained for each cell buffer associated 
with said group identifier and said scheduler is operative 
to select for transmission the partially received packet 
associated with the largest cell count in the event there are 
no fully received packets associated with said group 
identifier available for transmission. 
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BEST AVAILABLE IMAGES 

Defective images within this document are accurate representations of the original 
documents submitted by the applicant. 

Defects in the images include but are not limited to the items checked: 

□ BLACK BORDERS 

□ IMAGE CUT OFF AT TOP, BOTTOM OR SmES 

□ FADED TEXT OR DRAWING 

□ BLURRED OR ILLEGIBLE TEXT OR DRAWING 

□ SKEWED/SLANTED IMAGES 

□ COLOR OR BLACK AND WHITE PHOTOGRAPHS 

□ GStAY SCALE DOCUMENTS 

^ LINES OR MARKS ON ORIGINAL DOCUMENT 

□ REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY 

□ OTHER: 

IMAGES ARE BEST AVAILABLE COPY. 
As rescanning these documents will not correct the image 
problems checked, please do not report these problems to 
the IFW Image Problem Mailbox. 



